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Introduzione 

Esistono due tecniche di trasmissione 
dati: seriale e parallela. La prima è più 
semplice e economica, la seconda più 
veloce. Nel tuo Spectrum coesistono 
entrambe per permettere la 
comunicazione tra computer e 
periferiche e tra parti diverse del 
computer stesso. 

Abbiamo già accennato, poi, a come il 
computer può perdere delle “quasi 
decisioni", proseguiamo su questa 
strada, introducendo gli operatori 
logici (AND-OR-NOT) che permettono 
confronti e quindi decisioni, secondo 
schemi e strutture logiche simili a 
quelle seguite dall'uomo, nei suoi 
ragionamenti. 

E ancora ... STOP, CONTINUE, NEW, 
BREAK, CLEAR. 









Le porte 

Abbiamo visto nelle 
scorse lezioni (e lo 
vedremo anche nelle 
prossime!) come il cuore 
del calcolatore, cioè la 
CPU, sia in grado di 
effettuare - attraverso 
lunghe, ma velocissime 
serie di operazioni 
elementari - tutte le 
elaborazioni, i calcoli e 
gli ordinamenti necessari 
per portare a 
compimento le diverse 
sequenze di azioni 
specificate di volta in 


volta dal programma 
presente nella memoria. 
Elaborare dati per mezzo 
di un computer significa 
appunto raggiungere i 
diversi risultati attraverso 
tali serie di operazioni. 
Quella che però non è 
stata forse ancora 


sufficientemente 
specificata e sottolineata 
è l’estrema e 
fondamentale importanza 
che in tutto il processo 
assumono le varie unità 
periferiche. 

Ogni singolo calcolo 
comporta infatti un 
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insieme di operazioni (di 
lettura, localizzazione, 
elaborazione, 
trasferimento ed 
emissione), talmente 
complesso e molteplice 
che nessuna unità 
centrale “nuda e cruda”, 
priva cioè di adeguati ed 


opportuni supporti 
esecutivi, può essere in 
grado di affrontare e 
risolvere. 

Proponendoci di 
esaminare nelle 
prossime lezioni le 
descrizioni dettagliate e 
specifiche delle varie 


unità periferiche, 
vogliamo oggi occuparci 
di un argomento spesso 
sottovalutato o 
addirittura ignorato (ma 
non per questo di 
secondaria importanza, 
anzi!): le tecniche di 
collegamento e 






























comunicazione tra unità 
centrale e periferica o - 
detto in termini più 
generali - di 
interfacciamento tra 
unità centrale e mondo 
esterno. 


È chiaro (o almeno 
dovrebbe esserlo) che 
qualsiasi “colloquio” tra 
computer e periferica 
debba avvenire - 
indipendentemente dalla 
periferica - grazie ad un 
collegamento elettrico. 
Dobbiamo quindi vedere 
per prima cosa il modo 
in cui tali connessioni 
possono essere 
fisicamente realizzate. 
Escludendo l’ovvia 
presenza di uno o più 
cavi conduttori col 
compito di dover 
congiungere l’uno con 
l’altro i vari elementi, la 
parte principale del 
sistema di 
comunicazione è 
fondamentalmente 
costituita dalle 
cosiddette “porte” di 
ingresso/uscita. 

Una porta non è altro 
che un circuito elettrico 
(di solito inserito 
aN’interno del computer) 
in grado, a seguito di 
opportune e prefissate 
condizioni, di far entrare 
od uscire 
dall’elaboratore le 
informazioni che si 
possono rendere man 
mano necessarie o 
disponibili. 

Un esempio ti chiarirà 
immediatamente le idee. 
Quando batti un 
qualsiasi tasto sul tuo 
computer la pressione 
che hai esercitato sulla 


tastiera mette 
immediatamente in 
azione un particolare 
dispositivo che, come 
ben sai, genera la 
specifica combinazione 
di bit corrispondente al 
tasto premuto. 

Fino a questo punto la 
sequenza di bit è però, 
in un certo senso, 
esterna all’elaboratore: 
occorre infatti un 
ulteriore dispositivo che 
“interfacci” (cioè metta 
appropriatamente in 
comunicazione) il 
generatore dei codici dei 
caratteri con la memoria 
e l’unità centrale. Tale 
dispositivo è appunto 
una porta, in questo 
caso particolare una 
porta di ingresso, visto 
che l’informazione è in 
entrata: grazie ad essa il 
carattere premuto riesce 
così ad arrivare “dentro” 
il calcolatore, finalmente 
pronto e disponibile per 
le eventuali, ulteriori 
elaborazioni. 
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Tutto sembrerebbe 
semplice allora: quando 
la CPU desidera 
compiere una 
operazione di ingresso o 
di uscita le basta leggere 
o scrivere (mediante 


opportune procedure) il 
dato da scambiare per 
mezzo della porta 
corrispondente alla 
periferica selezionata, ed 
il problema è risolto. 
Purtroppo le cose non 
sono così semplici. La 
velocità di lavoro 
dell'unità centrale è 
infatti ben diversa da 
quella di una qualsiasi 
periferica. Se i dati da 
scambiare sono più di 
uno (e ciò accade nella 
stragrande maggioranza 
dei casi), può capitare 
che la CPU esegua 
l’insieme delle 
operazioni ad una 
velocità talmente elevata 
da tentare di leggere o 
scrivere nella porta 
ancora prima che la 
periferica abbia avuto il, 
tempo di “digerire” il 
dato precedente. 

Nel caso di un’istruzione 
di ingresso questo fatto 
provoca una doppia (o 
tripla, o quadrupla ...) 
lettura dello stesso dato, 
mentre nel caso di 
un’istruzione di uscita 
cambia le carte in tavola 
alla periferica nel bel 
mezzo di un’operazione, 
con risultati chiaramente 
imprevedibili. 

Si rende pertanto 
necessario un 
“serbatoio” intermedio, 
cioè un elemento nel 
quale tutte le 
informazioni possano 


accumularsi senza 
alcuna conseguenza per 
il regolare svolgimento 
delle operazioni. 

Questo serbatoio, 
tecnicamente chiamato 
buffer o memoria 
tampone, ha il compito 
di “assorbire" ad alta 
velocità i vari dati, 
“rilasciandoli” uno dopo 
l’altro, via via che la 
periferica è in grado di 
smaltirli. 

Entreremo comunque in 
ulteriori dettagli nelle 
prossime lezioni: per il 
momento è infatti 
necessario e sufficiente 
che tu abbia le idee 
chiare solo sui principi 
che stanno alla base dei 
vari processi. 
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HARDWARE 


Trasmissione 
seriale 
e parallela 


Parliamo adesso della 
realizzazione della 
connessione tra 
computer e periferica. 

È possibile riunire le 
tecniche di collegamento 
in due categorie 
generali: seriale e 
parallela. 

Nel collegamento seriale 
i bit che compongono 


ciascun dato (te ne 
ricordi? 8 bit = 1 byte) 
vengono inviati, uno 
dopo l’altro e sotto forma 
di impulsi elettrici, lungo 
uno stesso filo ad 
intervalli regolari di 
tempo. 

Attraverso il filo scorrono 
quindi, opportunamente 
distanziati tra di loro, 
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HARDWARE 


“treni” di impulsi, a 
ciascuno dei quali è 
fatto precedere un 
segnale di “arrivo di un 
dato” che per il circuito 
adibito alla ricezione ha 
appunto il preciso 
significato di prepararsi 
per l’arrivo del dato. 

È un tipo di 
collegamento molto 


economico e semplice 
da realizzare, e pertanto 
usato assai di frequente 
nei personal computer. 
Non consente però il 
raggiungimento di 
elevate velocità di 
comunicazione, né la 
realizzazione di 
connessioni troppo 
lunghe: al massimo 


qualche decina di metri. 
Questi difetti - se di 
difetti si può parlare - 
risultano comunque, 
nella maggior parte dei 
casi, assolutamente 
irrilevanti ai fini 
dell’utilizzo di un 
personal computer. 

Nel collegamento 
parallelo c'è invece un 
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filo per ogni bit da 
trasmettere; il cavo di 
collegamento è quindi 
costituito da 8 fili più 
altri fili ausiliari per 
utilizzi e comunicazioni 
di servizio, sui quali non 
è però assolutamente il 
caso di soffermarsi. 

I bit che compongono i 
dati da spedire non 


vengono più inviati l’uno 
dopo l'altro, ma l’uno 
accanto all’altro. È un 
po’ come se, in 
un’autostrada a 8 corsie, 
ciascun bit percorresse 
una corsia riservata solo 
ed esclusivamente ad 
esso. 

Il principale difetto di 
questa soluzione balza 
subito agli occhi: la 
realizzazione hardware 
non può infatti che 
influenzare notevolmente 
il costo di tutta la 
connessione. 

Ciò nonostante molte 
periferiche utilizzano 
come sistema di 
comunicazione il 
collegamento parallelo. 
Veniamo adesso alle 
norme costruttive. 

Sia nel collegamento 
seriale che in quello 
parallelo, allo scopo di 
assicurare un minimo di 
compatibilità tra 


dispositivi prodotti da 
ditte differenti, sono stati 
sviluppati dei protocolli 
di connessione e 
comunicazione, cioè 
degli standard, che 
stabiliscono come i fili 
devono essere collegati, 
che caratteristiche 
devono avere i segnali 
elettrici, in che ordine ed 
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a quale velocità vanno 
inviati i segnali, ecc.. 
Uno tra gli standard 
seriali più utilizzati (anzi, 
nel campo dei piccoli 
elaboratori praticamente 
l'unico) è la versione 
semplificata del 
protocollo RS 232 C/V 
24, chiamato 
familiarmente RS 232. 


A proposito di velocità di 
comunicazione: essa 
specifica il numero di bit 
che possono essere 
inviati ogni secondo 
lungo la linea. 

L’unità di misura è 
pertanto il bit per 
secondo (bps), chiamato 
anche baud rate. Valori 
tipici della velocità di 



trasmissione dei dati 
sono quelli compresi tra 
i 40 e 19200. 

Come hai potuto vedere, 
l’interfacciamento tra 
unità centrale ed una 
periferica è un 
argomento tutt'altro che 
di semplice e sbrigativa 
soluzione. Sono infatti 
necessari approfonditi 
studi sulle compatibilità 
tra i vari elementi, sugli 
standard ed i protocolli 
di comunicazione e sulle 
procedure costruttive. 
Nelle prossime lezioni, 
quando cioè parleremo 
in dettaglio delle singole 
periferiche, ritorneremo 
comunque più 
specificatamente 
sull’argomento. 
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LINGUAGGIO 


Gli operatori 
logici 


Abbiamo più volte detto, 
come la grande 
diffusione che i 
computer hanno avuto, e 
stanno attualmente 
avendo, dipenda in gran 
parte dalla loro estrema 
velocità e precisione 
neN’effettuare calcoli e 
confronti. 

Soprattutto i confronti 
consentono spesso e 
volentieri agli elaboratori 
di avvicinare ed emulare 
un modo di agire ed 
operare che all’uomo 
risulta particolarmente 
semplice, consueto e 
familiare: il confronto, 
cioè un ragionamento 
secondo schemi e 
strutture logiche. 

In questo ambito, quindi, 
gli uomini e le macchine 
si trovano perfettamente 
d’accordo: ciò che di 
solito è più semplice per 
l’uomo lo è infatti anche 
per la macchina, e 
viceversa. 

Tutti i linguaggi di 
programmazione 
annoverano e 
contemplano pertanto 
come una delle istruzioni 
più potenti ed importanti 
quella che consente 
materialmente di 
eseguire i confronti e le 
decisioni. Grazie ad essa 
è infatti possibile 
programmare seguendo 
lo stesso modello logico 
- normalmente basato su 
una serie di mutue 


esclusioni - che in fondo 
qualsiasi essere umano 
è sempre solito seguire 
ogniqualvolta si trova 
nelle condizioni di dover 
decidere tra un certo 
insieme di scelte o 
possibilità. 

Per esempio, la 
decisione conseguente 
ad un ragionamento del 
tipo: “Domani andrò a 
sciare, se ci sarà bel 
tempo, se Mario verrà 
insieme a me e se 
riuscirò ad alzarmi 
presto. Altrimenti andrò a 
farmi una bella 
passeggiata”, non potrà 
che essere raggiunta ed 
attuata soltanto dopo 
che saranno stati 
analizzati e valutati, uno 
per uno, tutti i fattori sui 
quali il ragionamento si 
basa e dai quali dipende 
interamente. 

È quindi necessario 
strutturare in maniera 
analoga anche le 
istruzioni dei programmi 
corrispondenti a tali 
decisioni. 
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LINGUAGGIO 


Sinora, però, tutte le 
espressioni condizionali 
(o relazionali) che 
abbiamo incontrato 
erano di tipo semplice: 
potevamo cioè operare 



sugli elementi della 
condizione (o della 
relazione) soltanto con 
una distinzione del tipo 
vero-falso, si-no, 
maggiore-minore, uno- 
zero. 

Si rende pertanto 
necessario, per essere in 
grado di eseguire 
aN’interno delle 
espressioni condizionali 
e logiche tutte le 
operazioni che possono 
diventare utili o 
necessarie, poter 
disporre di una nuova 
“famiglia” di operatori: i 
cosiddetti operatori 
logici. 

Finora avevamo infatti 
conosciuto ed utilizzato 
soltanto gli operatori 
aritmetici (con i quali 
elaborare le espressioni 
matematiche) e gli 
operatori relazionali 
(mediante cui eseguire i 
confronti). Gli operatori 
logici vengono invece 
usati per combinare in 
un unico risultato logico 
due distinti valori logici. 
Gli operatori logici sono: 


AND (l'uno e l’altro) 
OR (l’uno o l’altro) 
NOT (negazione) 


Un confronto del tipo: 5 
> 3 è verificato, cioè è 
vero; all’espressione 5 > 
3 viene allora 
convenzionalmente 
assegnato il valore 1. 


il 






LINGUAGGIO 


La condizione 8 < 5 è 
invece non verificata, 
cioè è falsa; 
all’espressione 8 <5 
compete quindi (sempre 
per convenzione) il 
valore 0. 

Sfruttando questo fatto è 
pertanto possibile 


scrivere istruzioni del 
tipo: 

LET A = (5 > B) 

Alla variabile A viene 
assegnato il valore 0 od 
1, in dipendenza del 
fatto che B risulti 
maggiore o minore di 5 
oppure: 

LET K = (4 = A) 

K varrà 0 od 1, se A 
risulterà diverso od 
uguale a 4. 


NOT 


NOT è la più elementare 
operazione logica; essa 
significa negazione, cioè 
inversione dello stato di 
una variabile o di una 
relazione. 

Così, se A è una 
variabile di valore 0, la 
sua negazione - NOT A 
- vale 1. Se invece A 
assume un qualsiasi 
altro valore diverso da 0, 
NOT A vale 0. 
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LINGUAGGIO 


Esempi 


Assegna a S il valore 0 

LET S = NOT 5 


LET J = NOT 0 


Assegna a J il valore 1 


7 è maggiore di 3, quindi 

LET A = (NOT (7 > 3)) < > 0 7 > 3 è considerato 1. 

NOT 1 è uguale a 0. 
Poiché zero non è 
diverso da zero, A 
assumerà quindi valore 
0 . 
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LINGUAGGIO 


Tabella 
della verità 

Spesso torna utile far 
ricorso alla cosiddetta 
tabella della verità. 
Questa non è altro che 
una schematica 
rappresentazione 
dell'operatore logico, 
avente come scopo 
quello di fornire tutti i 
risultati corrispondenti 
alle diverse possibili 
combinazioni 
dell’espressione, 
precisando e 
visualizzando 
rapidamente le relazioni 
intercorrenti tra valori in 
ingresso e risultati in 
uscita. 

La tabella della verità di 
NOT è molto semplice: 


ingresso 

uscita 

1 

0 

0 

1 


OR 


L’OR, o somma logica, 
viene invece definito in 
questo modo: “la somma 
logica tra due 


espressioni logiche è 
vera (cioè uguale ad 1), 
se anche una solo, di 
esse è vera (cioè 1); se 
entrambe sono false 
(uguali a 0), la somma 
logica è falsa”. 

Se allora definiamo la 
variabile C in questo 
modo: 


LET C = (A >1) OR (B >2) 

ad essa verrà assegnato 
valore 1, se almeno una 
delle due espressioni 
entro parentesi risulterà 
verificata, cioè uguale a 
1. Se invece nessuna 


delle due parentesi sarà 
vera, C varrà 0. 



























LINGUAGGIO 


Esempi 

LET J = (5 > D) OR (Z = 9) 


J varrà 1, se D risulterà 
minore di 5 o se Z sarà 
pari a 9. Varrà 0 in caso 
contrario. 


LET M = (NOT A) OR B 


Se B risulterà diverso da 
zero (infatti NOT 0 = 1), 
ad M sarà assegnato 
valore 1. Altrimenti M 
varrà 0. 



La tabella 
della verità 

La tabella della verità di 
OR è la seguente (A e B 
sono due qualsiasi 
espressioni logiche): 


A 

B 

A OR B 

0 

0 

0 

1 

0 

1 

0 

1 

1 

1 

1 

1 


Come puoi vedere, 
l’unico caso che può 
rendere A OR B pari a 
zero è quello in cui 
entrambe le espressioni 
risultano false, cioè pari 
a zero. 
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LINGUAGGIO 


AND 


L’ultimo operatore logico 
che ci resta da 
esaminare è AND (o 
prodotto logico). 


Esso è definito nel 
seguente modo: “il 
prodotto logico tra due 
espressioni logiche è 
vero (quindi pari ad 1), 
se e solo se entrambe le 
espressioni sono vere 
(uguali ad 1)”. 

La variabile F, definita 


come 

risulterà pertanto pari ad 
1 soltanto se entrambe 
le espressioni aM’interno 
delle parentesi 
risulteranno verificate, 
cioè se A sarà maggiore 
di 1 e B maggiore di 2. 
Se invece anche una 
sola delle due parentesi 
conterrà un’espressione 
falsa, F assumerà valore 
zero. 


LET F = (A >1) AND (B >2) 












LINGUAGGIO 


Esempi: 

I assumerà valore 1 se G 

LET I = (G = 3.1) AND (T = 4.5) e T avranno valore 

rispettivamente uguale a 
3.1 e 4.5. 


Perché A assuma valore 
LET A = (K > 3 OR J < 1) AND P 1, deve risultare P< > 0, 

e K > 3 oppure J < 1. 


La tabella 
della verità 


A 

B 

A AND B 

0 

0 

0 

0 

1 

0 

1 

0 

0 

1 

1 

1 



Questa volta l’unico 
modo per ottenere un 
risultato vero è che 
entrambe le espressioni 
risultino vere, cioè 1. 

In un certo senso si può 
quindi dire che il 
prodotto logico è 
l’operazione inversa alla 
somma logica (se provi a 
confrontare le due 
tabelle AND OR, te ne 
renderai subito conto). 
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LINGUAGGIO 


Priorità 

degli operatori 
logici 


Anche gli operatori logici 
hanno una loro priorità, 
analogamente agli 
operatori matematici. 
L’ordine delle priorità 
nelle operazioni logiche 
è infatti, partendo dalla 
più bassa alla più alta, 
OR, AND, NOT. 

Tali precedenze 
possono naturalmente 
sempre essere alterate 
facendo uso delle 
parentesi: anzi, visto che 
l'occhio umano non è 
molto abituato a leggere 
espressioni come 


STOP 


Immagina di essere in 
una sala di regia seduto 
davanti alla moviola: stai 
verificando la sequenza 
delle immagini di un film. 
All'Improvviso ti accorgi 
che manca la sequenza 
centrale (quella che 
spiega “i risvolti 
psicologici” del 
protagonista). 

Interrompi allora la 
proiezione, cerchi e (per 
fortuna) trovi il pezzo 
mancante, senza il quale 
il film sarebbe risultato 
un “polpettone", e lo 
incolli nel punto esatto 
in cui era previsto. 

Ora è tutto a posto e la 
proiezione può 
proseguire. 

Trasferisci adesso tutto il 
discorso su un altro 
piano: il film è un 
programma e tu, da 
operatore, diventi un 
programmatore, 
il programma non 
funziona nel migliore dei 
modi: per quanto esso 
sembri non evidenziare 
alcun errore lampante e 
palese, ad un certo 
punto si blocca con un 
messaggio di errore. 

Ti farebbe proprio 
comodo un’istruzione 
che potesse arrestare 
momentaneamente 
l’esecuzione, 


A = NOT C > A AND B OR D AND C 


sarà meglio, per evitare 
facili errori o confusioni, 
utilizzare sempre e 
comunque le parentesi: 


A = (NOT (C > A) AND B) OR (D AND C) 


Nella parte della lezione 
dedicata alla 
programmazione troverai 
comunque alcuni esempi 
applicativi, che ti 
consentiranno di 
acquisire maggiore 
pratica e familiarità 
sull’uso degli operatori 
logici. 
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consentendoti di 
controllare alcuni 
risultati intermedi e di 
riprendere come se 
niente fosse accaduto 



Che fare? 

Il BASIC, per i casi come 
questo, ti mette a 
disposizione l’istruzione 
STOP. 

Infatti STOP, ferma 
l’esecuzione di un 
programma e provoca la 
visualizzazione di un 
messaggio indicante la 
linea di programma nella 
quale l’interruzione è 
avvenuta, proprio come 
se si fosse verificato un 
errore. 
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Il grosso vantaggio è 
che dopo una STOP il 
computer si pone nel 
modo “editor”: puoi cioè 
inserire nuove linee, 
apportare correzioni, 
esaminare o modificare 
il valore delle variabili. 


Naturalmente, una volta 
risolti tutti i problemi è 
bene che gli STOP siano 
eliminati. A nessuno, fa 
piacere vedere un 
programma arrestarsi nel 
bel mezzo 
dell’esecuzione! 

Così, per esempio, la 
linea 


150 STOP 


visualizzerà, quando 
eseguita: 


9 STO P STATEM ENT, 150 


avvertendoti che 
l’interruzione del 
programma si è 
verificata alla linea 150, 
in seguito ad 
un’istruzione STOP. 
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CONTINUE 


Come alla moviola è 
possibile riprendere la 
proiezione dal punto 
esatto di interruzione, 
anche in un programma 


che è stato bloccato in 
seguito ad una STOP è 
possibile riprendere 
l’esecuzione, grazie al 
comando CONTINUE 
(che ovviamente va 
impartito in modo 
immediato). 

STOP e CONTINUE 


costituiscono pertanto 
un utilissimo strumento 
per il debugging, cioè 
per la correzione e la 
messa a punto dei 
programmi. 

Con essi puoi infatti 
controllare i punti 
strategici di un 
programma, 
eventualmente 
modificando e 
migliorando quelle 
istruzioni che in un 
primo tempo ti 
sembravano 
perfettamente corrette, 
senza però per questo 
interrompere in modo 
definitivo l’elaborazione 
che era in corso fino a 
quel momento. 



Sintassi del comando 




CONTINUE 
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NEW 


Talvolta, hai la necessità 
di cancellare un 
programma dalla 
memoria del computer. 

In questo caso due sono 
le possibili alternative: 
togliere semplicamente 
l'alimentazione al 
computer, per poi 
riaccenderlo, oppure - 
con molta più eleganza - 
impartire il comando 
NEW. 


NEW serve infatti per 
cancellare il programma 
BASIC presente in 
memoria insieme a tutte 
le variabili. Normalmente 


lo si usa quando si inizia 
a scrivere un nuovo 
programma e si vuole 
essere sicuri che non vi 
sia alcuna istruzione, o 
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parte di programma, già 
presente in memoria. 

È naturalmente un 
comando da utilizzare 
con molta attenzione: un 



NEW impartito senza 
troppa cura può infatti 
provocare in un attimo la 
scomparsa di ore ed ore 
di lavoro alla tastiera. 


NEW viene solitamente 
adoperato in esecuzione 
immediata; tuttavia lo 
puoi inserire anche 
aH’interno di un 
programma: 


190 REM ATTENZIONE: RISPONDENDO CON NO 
PERDI IL PROGRAMMA 
200 IF A$ = "NO” THEN NEW 


In questo caso, però, 
devi tener ben presente 
che, al momento 
dell’esecuzione della 
linea 200, l’intero 
programma verrà 
cancellato, provocando 
come conseguenza 
l'istantaneo arresto di 
qualsiasi attività del 
calcolatore. 

Sarà comunque buona 
cosa che prima di 
inserire questo comando 
in un programma tu 
impari a utilizzarlo ed a 
capirne l’esatto 
funzionamento nel più 
classico (e sicuro) 
utilizzo immediato. 


Sintassi del comando 

NEW 
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Come 

interrompere 
un programma 


dell’elaborazione. 

Ci sono casi però, in cui 
si rende necessario 
interrompere il problema 
con una decisione 


esterna al programma 
stesso: il caso tipico è 
quello di un errore in 
grado di innescare un 
loop senza fine, dal 



Abbiamo già visto come 
è possibile fermare 
l’esecuzione di un 
programma tramite 
l'istruzione STOP, 
collocata nel punto del 
listato in cui desideriamo 
l'arresto 
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quale non si uscirebbe 
mai se non togliendo 
l’alimentazione. 

Questa soluzione ha 
però purtroppo lo 


svantaggio di far perdere 
tutti i dati in memoria, 
obbligando a 
ricominciare da capo o a 
ricaricare il programma. 
Pensa al caso di una 
lista come: 

230 GO TO n 

dove n, per un qualsiasi 
motivo, abbia assunto il 
valore 230. 

In situazioni come 
questa, puoi 
provvidenzialmente 
uscirne senza danno 
grazie alla pressione di 
due tasti posti alle 
estremità della fila in 
basso della tastiera: 
CAPS SHIFT e SPACE. 
Premili 

contemporaneamente ed 
il programma si arresterà 
restituendoti il controllo 
del computer. 

Apparirà 

contemporaneamente 
sullo schermo il 
messaggio 

L BREAK 
INTO PROGRAM 


Hai così la possibilità di 
apportare le correzioni 
necessarie al listato ed 
eventualmente 
riprendere l’elaborazione 
tramite un GO TO alla 
linea modificata. 

È possibile inoltre 
sospendere un 


programma anche per 
altri motivi: poni il caso 
che lo squillo del 
telefono ti colga mentre 
stanno uscendo i dati 
che ti interessano, puoi 
fare tre cose: 

1) lasciar perdere 
la chiamata 

2) perdere i dati 
interessati 

3) “BREKKARE” il 
programma, rispondere 
al telefono e poi 
riprendere dal punto 

in cui era stata sospesa 
l’esecuzione. 

BREAK può essere usato 
anche durante il 
funzionamento del 
registratore o di una 
periferica come 
la stampante. 

In questo caso, 
a differenza dei 
precedenti, è sufficiente 
la pressione del solo 
tasto SPACE; il 
messaggio visualizzato, 

D BREAK - CONT 

REPEATS 

ricorda come il 
comando CONTINUE 
faccia ripetere 
l’istruzione interrotta 
anziché passare a quella 
successiva. 
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CLEAR 


CLEAR è un’istruzione 
molto meno drastica 
della NEW. 

Si limita infatti a 
cancellare tutte le 
variabili in memoria, ma 
non il programma che 
resta a disposizione per 
ulteriori utilizzi. 

Un altro effetto di CLEAR 
è quello di ripulire lo 
schermo, analogamente 
a quanto accade a 
seguito dell’istruzione 
CLS. 

Verifica personalmente 
quanto detto 
introducendo nel tuo 
Spectrum il seguente 
programma: 


10 LET A = 23 
20 LET B= 12 
30 LET S — A + B 
40 PRINT S 

50 PRINT “EFFETTO CLEAR 
60 PAUSE 100 
70 CLEAR 
80 PRINT S 


Apparirà il messaggio di 
errore “2 VARIABILE 
NOT FOUND, 80 : 1” a 
dimostrare come 
la linea 70 abbia cancellato 
le variabili. 

Richiedi ora il listato con 
LIST e verifica che il 
programma sia sempre 
presente in memoria. 
CLEAR si può 
inoltre utilizzare con un 
argomento numerico che 
indica l’ultima cella di 
memoria raggiungibile 
dal programma BASIC. 
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cancellate nemmeno da 
NEW. 

Il numero da fornire a 
CLEAR deve essere 
compreso tra quello 
dell’ultima cella fisica 
della memoria (65535) e 
la prima non occupata 
dal programma BASIC e 


dal Sistema Operativo. 

Il messaggio di errore 
“RAMTOP NO GOOD” 
indica la necessità 
di incrementare il valore 
fornito, mentre “INTEGER 
OUT OF RANGE” avverte 
di abbassarlo. 

Introduci, alla tastiera 
questi esempi: 


Ciò può essere molto 
utile quando occorre 
preservare una certa 
porzione della memoria 
per dati particolari e si 
vuole evitare che il 
programma BASIC, 
durante la sua scrittura, 
possa sconfinare e 
distruggerli. 

La locazione di questa 
cella limite si chiama 
RAMTOP; tutte le 
informazioni 
memorizzate al di sopra 
di essa non vengono 


10 REM PROVA 

20 CLEAR 28000 

30 POKE 28001, 65 

40 REM HO SCRITTO UNA A IN 28001 

50 PRINT "ORA VADO IN NEW” 

60 PAUSE 200 
70 NEW 

Chiedi ora il Listato con 
LIST: nessuna traccia 
del programma. 

Digita: 


PRINT CHR$ (PEEK 28001) 


Qual è il risultato? 




_ 
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Applicazione 
degli operatori 
logici 


Ci proponiamo di 
risolvere il seguente 
problema: dati in 
ingresso tre numeri 
qualsiasi, trovarne il 
maggiore ed il minore. 
Supponendo di chiamare 
A, B, C le variabili adibite 
aM’inserimento nel 
calcolatore dei tre valori 
numerici, un possibile 
schema a blocchi 
potrebbe essere: 


L’estrema semplicità del 
problema non richiede di 
certo alcuna spiegazione 
sul flowchart. 

Qualche parola è invece 
necessario spenderla 
sulla conversione del 
diagramma nel 
corrispondente 
programma BASIC di cui 
troverai più avanti due 
distinte versioni. 

Il tuo computer le 


INIZIO 


I 
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ft 


gradirà entrambe: dal 
suo punto di vista, infatti, 
una volta che la sintassi 
risulta corretta non 
esiste alcuna differenza 
tra l'una o l’altra. 

Noi, invece, ci 
accorgiamo 
immediatamente della 
differente impostazione, 
struttura e leggibilità 
intercorrente tra i due 
listati. Grazie all’uso 


intensivo degli operatori 
logici, seguire, 
comprendere e - 
soprattutto - controllare 
la funzione, l’esecuzione 
e lo svolgimento di ogni 
singola istruzione della 
seconda versione 
dovrebbe risultare difatti 
molto più semplice e 
lineare di quanto non sia 
possibile fare con la 
prima. 


Ciò è dovuto in gran 
parte all’assenza di 
istruzioni GOTO, il cui 
difetto è spesso quello di 
interrompere la trama 
logica che si era seguita 
al momento della stesura 
dello schema a blocchi. 
Un consiglio quindi: 
impara da subito a 
programmare, cercando 
di seguire questa 
impostazione e 
diventerai un ottimo 
programmatore. 


10 INPUT A, B, C 

20 IF A > = B AND A > = C AND B > = C THEN LET MAX = A : LET MIN = C 
30 IF A > = B AND A > = C AND NOT (B > = C) THEN LET MAX = A : LET 
MIN = B 

40 IF A > = B AND NOT (A > = C) THEN LET MAX = C : LET MIN = B 
50 IF NOT (A > = B) AND NOT (B > = C) THEN LET MAX = C : LET MIN = A 
60 IF NOT (A > = B) AND B > = C AND A > = C THEN THEN LET MAX = 

B : LET MIN = C 

70 IF NOT (A > = B) AND B > = C AND NOT (A > = C) THEN LET MAX = 

B : LET MIN = A 

80 PRINT “IL VALORE MASSIMO È”; MAX 
90 PRINT “IL VALORE MINIMO È”; MIN 


10 INPUT A, B, C 

20 IF A > = B THEN GOTO 40 

30 GOTO 80 

40 IF A > = C THEN GOTO 60 
50 LET MAX = C : LET MIN = B : GOTO 120 
60 IF B > = C THEN LET MIN = C : LET MAX = A : GOTO 120 
70 LET MIN = B : LET MAX = A : GOTO 120 
80 IF B > = C THEN GOTO 100 
90 LET MAX = C : LET MIN = A : GOTO 120 
100 IF A > = C THEN LET MAX = B : LET MIN = C : GOTO 120 
110 LET MAX = B : LET MIN = A 

120 IF MAX = MIN THEN PRINT “VALORI UGUALI’’: STOP 
130 PRINT “IL VALORE MASSIMO È”; MAX 
140 PRINT “IL VALORE MINIMO È”; MIN 
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A proposito: un’ultima 
osservazione, questa 
volta riguardo alla 
sintassi. Cosa 
succederebbe se per 
esempio alla riga 

30 IF A > = B AND A > = C AND NOT (B > = C) THEN LET MAX = A : LET 
MIN = B 

non venissero messe le 
parentesi? 

30 IF A > = B AND A > = C AND NOT B > = C THEN LET MAX = A : LET 
MIN = B 


Prova a pensarci! È 
rilevante la priorità di 
esecuzione delle 
operazioni logiche). 
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Il aioco 
della parola 

È un semplice gioco per 
due o più concorrenti: il 
compito di ciascuno è di 
introdurre a turno, da 
tastiera, una lettera 
dell’alfabeto (compresa 
cioè tra A e Z). 

Un possibile 
regolamento potrebbe 
assegnare la vittoria 
al giocatore che, 
aggiungendo una lettera, 
formerà una parola di 
senso compiuto, o, al 
contrario, dichiarare 


perdente quello stesso 
giocatore. 

Il programma fa uso 
dell’operatore logico OR 
per verificare la validità 
del carattere introdotto e, 
sempre per lo stesso 
motivo, utilizza l’INKEY$ 
al posto dell’INPUT. 
Importantissimo, inoltre, 
il simbolo di 
punteggiagura: dopo la 
variabile nella linea LO, 
che consente di lasciare 
invariata la posizione 
stampa (per renderti 
conto della sua 
importanza, prova ad 
eliminarlo). 


IMMETTI 

CARATT. 


RUN 

L 

si 


C$ = “0”? 


FUORI 

LIMITI? 


SI 


STAMPA 


RITORNA 


10 PAUSE 0 : LET C$ = INKEY$ 

20 IF C$ = “0” THEN RUN 

30 IF C$ < “A” OR C$ > “Z” THEN GO TO 10 

40 PRINT C$; 

50 GO TO 10 
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Annota nello spazio apposito il risultato da te previsto per ciascun esercizio 
proposto e poi verificaio con la soluzione del tuo computer. Se avrai commesso 
anche un solo errore, ripassa la lezione. 

10 LET A = 12 : LET B = 5 : LET N$ = “BENE" 

20 IF A < B THEN PRINT “MELE” 

30 IF B < A THEN PRINT “BANANE" 

40 IF (A + B) < > (B + A) THEN PRINT N$ 


Quale è la materia considerata più importante in questo listato? 

10 CLS : PRINT “CHE VOTO MERITI?” 

20 INPUT “TEORIA"; T 

30 INPUT “PROGRAMMAZIONE”; P 

40 LET M = T + P/2 

50 IF P > = 7 AND M > 6 THEN PRINT “PROMOSSO” 

60 IF P < 7 OR M < = 6 THEN PRINT “RESPINTO” 

Secondo te, con 3 in teoria e 8 in programmazione si è promossi? 


Quante volte verrà eseguita l’elaborazione di questo Loop? 

10 FOR I = 1 TO 10 
20 PRINT I : CLEAR 
30 NEXT I 
Perché? 


Per chi ama nascondere i propri segreti ... 

10 PAPER 2 : INK 2: CLS 
20 PRINT AT 4, 4; “È UN SEGRETO” 

30 PAUSE 100 

40 INK 7 : PRINT AT 10,4; “NON È UN SEGRETO” 

Una tecnica usata per nascondere i listati da sguardi indiscreti è quella di 
stamparli con inchiostro uguale al colore dello sfondo (carta). 
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